<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <meta http-equiv="X-UA-Compatible" content="ie=edge" />
    <title>文章列表</title>
    <link rel="stylesheet" href="./libs/bootstrap/css/bootstrap.min.css" />
    <link rel="stylesheet" href="./css/reset.css" />
    <link rel="stylesheet" href="./css/iconfont.css" />
    <link rel="stylesheet" href="./css/main.css" />
    <script src="./libs/jquery-1.12.4.min.js"></script>
    <!-- 引入模板引擎js文件 -->
    <script src="./libs/template-web.js"></script>
    <!-- 导入分页导航插件 -->
    <script src="./libs/jquery.twbsPagination.js"></script>
  </head>

  <body>
    <div class="container-fluid">
      <div class="common_title">
        文章列表
      </div>
      <div class="container-fluid common_con">
        <div class="row opt_btns">
          <div class="col-xs-6">
            <form class="form-inline">
              <select id="selCategory" name="" class="form-control input-sm">
                <option value="">所有分类</option>
                <option>未分类</option>
                <option>奇趣事</option>
                <option>会生活</option>
                <option>爱旅行</option>
              </select>
              <select id="selStatus" name="" class="form-control input-sm">
                <option value="">所有状态</option>
                <option value="草稿">草稿</option>
                <option value="已发布">已发布</option>
              </select>
              <button id="btnSearch" class="btn btn-default btn-sm">
                筛选
              </button>
            </form>
          </div>
          <div class="col-xs-6">
            <a
              href="article_release.html"
              class="btn btn-success btn-sm pull-right"
              id="release_btn"
              >发表文章</a
            >
          </div>
        </div>
        <table class="table table-striped table-bordered table-hover mp20">
          <thead>
            <tr>
              <th>标题</th>
              <th>作者</th>
              <th>分类</th>
              <th class="text-center">发表时间</th>
              <th class="text-center">状态</th>
              <th class="text-center" width="100">操作</th>
            </tr>
          </thead>
          <tbody>
            <tr>
              <td>王积千造统最头</td>
              <td>杰克</td>
              <td>奇趣事</td>
              <td class="text-center">2017-06-08 07:08:46</td>
              <td class="text-center">已发布</td>
              <td class="text-center">
                <a href="article_edit.html" class="btn btn-default btn-xs"
                  >编辑</a
                >
                <a
                  href="javascript:void(0);"
                  class="btn btn-danger btn-xs delete"
                  >删除</a
                >
              </td>
            </tr>
          </tbody>
        </table>
        <div class="row text-center">
          <!-- 分页导航容器 -->
          <ul id="pagination" class="pagination-sm"></ul>
        </div>
      </div>
    </div>
  </body>
</html>

<script src="./libs/https.js"></script>

<!-- 文章类别模板 -->
<script type="text/html" id="tpl-category">
  <option value="">所有分类</option>
  {{each data}}
  <option value="{{$value.id}}">{{$value.name}}</option>
  {{/each}}
</script>

<!-- 文章列表模板 -->
<script type="text/html" id="tpl-list">
  {{each  data.data}}
            <tr>
               <td>{{$value.title}}</td>
                <td>{{$value.author}}</td>
                <td>{{$value.category}}</td>
                <td class="text-center">{{$value.date}}</td>
                <td class="text-center">{{$value.state}}</td>
                <td class="text-center">
                  <a href="article_edit.html?id={{$value.id}}" data-id={{$value.id}} class="btn btn-default btn-xs" >编辑</a>
                  <a href="javascript:void(0);"data-id={{$value.id}} class="btn btn-danger btn-xs delete" >删除</a >
                </td>
              </tr>
  {{/each}}
</script>

<script>
  $(function () {
    //1.获得当前所有的文章类别,生成下拉框
    $.ajax({
      url: BigNew.category_list,
      type: 'get',
      success: function (backData) {
        console.log(backData)
        if (backData.code == 200) {
          //2.结合模板引擎生成标签结构
          let htmlStr = template('tpl-category', backData)
          $('#selCategory').html(htmlStr)
        }
      }
    })

    //3.获得当前页面的文章列表数据
    let selpage = 1 //声明一个变量来保存当前被选中的页码

    //封装函数:获得文章列表数据
    //page:当前被选中的页码
    function loadData (page) {
      selpage = page
      //4.发送请求
      $.ajax({
        url: BigNew.article_query,
        type: 'get',
        data: {
          //请求文章的类型
          type: $('#selCategory').val(),
          //请求文章的状态
          state: $('#selStatus').val(),
          //请求某一页的数据
          page: page,
          //每一页多少条数据
          perpage: 5
        },
        success: function (backData) {
          console.log(backData)
          if (backData.code == 200) {
            //判断当前的请求是否有返回数据
            if (backData.data.totalCount > 0) {
              //有数据,则需要渲染结构,以及设置分页导航
              //5.根据返回的数据,渲染页面结构

              let htmlStr = template('tpl-list', backData)
              $('tbody').html(htmlStr)

              //6.根据数据来设置分页导航
              //分页插件的属性设置只有第一次才能生效,第一次设置的总页数
              $('#pagination').twbsPagination('destroy') //摧毁
              $('#pagination').twbsPagination({
                //总页数
                totalPages: backData.data.totalPage,
                //可见页数
                visiblePages: 7,
                //当前选中的页码
                startPage: page,
                //关闭初始化点击事件
                initiateStartPageClick: false,
                //修改按钮的文字
                first: '首页',
                last: '尾页',
                next: '下一页',
                prev: '上一页',
                //分页导航页码点击事件
                onPageClick: function (event, page) {
                  //page:当前点击的页面
                  //页码被点击的时候,应该请求相对应数字的文章数据
                  // console.log(page);
                  loadData(page)
                }
              })
            } else {
              //当前请求没有任何的文章数据
              //清空表格内容,再显示文本提示
              $('tbody').empty()
              $('#pagination').text('当前类别没有任何文章....')
            }
          }
        }
      })
    }
    //首次加载第一页的数据
    loadData(1)

    //7.给筛选按钮设置点击事件
    $('#btnSearch').on('click', function (e) {
      e.preventDefault()
      //重新获得文章数据,渲染结构
      loadData(1)
    })

    //8.设置删除按钮点击事件
    $('tbody').on('click', '.delete', function () {
      //9.获得当前文章id
      let dataid = $(this).attr('data-id')
      //10.发起ajax请求,删除文章数据
      $.ajax({
        url: BigNew.article_delete,
        type: 'post',
        data: {
          id: dataid
        },
        success: function (backData) {
          if (backData.code == 204) {
            //11.删除成功之后,重新加载数据
            //判断当前是否为最后一页最后一条数据被删除
            //判断当前的表格tr的长度大于1
            if ($('tbody tr').length > 1) {
              //注意:在哪一页删除,就在哪一页刷新
              loadData(selpage)
            } else {
              //此刻应该加载上一页的数据
              //如果删除的是第x页的最后一条,那就应该加载第x-1页的数据
              loadData(selpage - 1)
            }
          }
        }
      })
    })
  })
</script>
